package org.example.mapper;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;
import org.example.entity.ReactionTestRecord;

import java.util.List;

/**
 * 反应测试记录Mapper接口
 */
@Mapper
public interface ReactionTestRecordMapper extends BaseMapper<ReactionTestRecord> {
    
    /**
     * 根据用户ID查询历史记录（分页）
     * @param userId 用户ID
     * @param offset 偏移量
     * @param limit 查询数量限制
     * @return 测试记录列表
     */
    List<ReactionTestRecord> selectByUserId(@Param("userId") Long userId, @Param("offset") Integer offset, @Param("limit") Integer limit);
    
    /**
     * 查询用户最佳成绩
     * @param userId 用户ID
     * @return 最佳成绩记录
     */
    ReactionTestRecord selectBestByUserId(@Param("userId") Long userId);
    
    /**
     * 获取排行榜数据
     * @param limit 数量限制
     * @return 排行榜记录列表
     */
    List<ReactionTestRecord> selectRanking(@Param("limit") Integer limit);
}